<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        let number=18;
        let person={
            name:"张三",
            sex:'男'
        }
        Object.defineProperty(person,'age',{
            // value:18,
            // enumerable:true,//控制属性是否可枚举，默认false
            // writable:true,//控制属性是否可以被修改，默认false
            // configurable:true,//控制属性是否可以被删除，默认为false
            // 当读取person的age属性时get函数就会被调用，且返回值就是age的值
            get:function(){
                console.log('读取ages属性中。。。');
                return number;
            },
            //当有人修改person的age属性时，set函数(setter)就会被调用，且会收到修改的具体值
            set(value){
                console.log('修改了age属性为',value)
                number=value;
            }
        });
        console.log(person);
    </script>
</body>
</html>